草庐IT

node.js - Mongoose 获取与数组匹配的文档

全部标签

ruby - 对文件进行符号链接(symbolic link)后,如何在 Ruby 中获取原始文件的路径?

我有一个路径为/foo/bar/gazook/script.rb的Ruby脚本。我还在$HOME/bin中创建了指向它的符号链接(symboliclink)。现在,我希望我的Ruby脚本访问目录/foo中的一些其他文件,并保持路径相对,我有一个变量FOO_DIRECTORY=File.expand_path(File.dirname(__FILE__)+"/../../")在我的脚本中。问题是,如果我从它的符号链接(symboliclink)运行我的脚本,这个相对目录是错误的(因为我猜它是从不同的位置扩展的)。我该如何解决这个问题?除了使用绝对路径还有其他方法吗?

ruby - 尝试使用 nokogiri 获取 xml 文件中 cdata 标签内的内容

我已经看到了几件事,但到目前为止似乎没有任何效果。我正在使用nokogirionrails3ruby​​1.9.2通过url解析xml。xml的片段如下所示:我正在尝试解析它以获取与NewsLineText关联的文本r=node.at_xpath('.//newslinetext')ifnode.at_xpath('.//newslinetext')s=node.at_xpath('.//newslinetext').textifnode.at_xpath('.//newslinetext')t=node.at_xpath('.//newslinetext').contentifnod

ruby-on-rails - Rails - 如何获取访问者的IP地址?

我需要将访问者的IP地址存储到我们的数据库中,这是我尝试这样做的方式:@ip=request.remote_ip@ip=request.env['REMOTE_ADDR']但在这两种情况下,@ip变量都存储了值127.0.0.1,即使我将应用程序部署到AmazonEC2实例也是如此。当我检查http://www.whatismyip.com/时,它将我的IP显示为109.175.XXX.X。那么为什么ruby变量总是显示127.0.0.1地址呢?如何获取真实IP?编辑:这是以下内容的输出:request.env['HTTP_X_FORWARDED_FOR']=>request.remo

arrays - 从数组中删除并返回 Ruby 中删除的元素

如何从数组中删除一些元素并选择它们?例如:classFoodefinitialize@a=[1,2,3,4,5,6,7,8,9]enddefget_areturn@aendendfoo=Foo.newb=foo.get_a.sth{|e|e[1,2,3]pfoo.get_a#=>[4,5,6,7,8,9,10]我可以用什么代替foo.get_a.sth? 最佳答案 如果不需要保留a的对象id:a=[1,2,3,4,5,6,7,8,9,10]b,a=a.partition{|e|e[1,2,3]a#=>[4,5,6,7,8,9,10]

ruby - 将带有值数组的 ruby​​ 散列合并到另一个带有值数组的散列中

我似乎找不到任何地方谈论这样做。假设我有一个散列{"23"=>[0,3]},我想合并到这个散列{"23"=>[2,3]}生成此哈希{"23"=>[0,2,3]}或者{"23"=>[3]}与{"23"=>0}合并如何得到{"23"=>[0,3]}谢谢! 最佳答案 {"23"=>[0,3]}.merge({"23"=>[2,3]})do|key,oldval,newval|oldval|newvalend#=>{"23"=>[0,3,2]}处理非数组值的更通用的方法:{"23"=>[0,3]}.merge({"23"=>[2,3]})d

ruby - XPath 轴,获取所有后续节点直到

我有以下HTML示例:FoobarloremipsumetcBarbazdumdumdumpoopfiddles我希望提取“Foobar”标题后的所有段落,直到到达“Barbaz”标题(“Barbaz”标题的文本未知,所以很遗憾我无法使用答案由bougyman提供)。现在我当然可以使用//h2[text()='Foobar']/following::p之类的东西,但这当然会抓取此后的所有段落header。因此,我可以选择遍历节点集并将段落插入数组,直到文本与下一个header的文本相匹配,但老实说,这远不如在XPath中完成这件事那么酷。有没有办法做到这一点我想念的?

ruby - 如何将 Ruby 数组存储到文件中?

如何将Ruby数组存储到文件中? 最佳答案 我不确定你到底想要什么,但是,要序列化一个数组,将它写入一个文件并读回,你可以使用这个:fruits=%w{mangobananaappleguava}=>["mango","banana","apple","guava"]serialized_array=Marshal.dump(fruits)=>"\004\b[\t\"\nmango\"\vbanana\"\napple\"\nguava"File.open('/tmp/fruits_file.txt','w'){|f|f.write

Ruby 方法 Array#<< 不更新散列中的数组

灵感来自HowcanImarshalahashwitharrays?我想知道是什么原因Array#在以下代码中将无法正常工作:h=Hash.new{Array.new}#=>{}h[0]#=>[]h[0]["a"]h[0]#=>[]#why?!h[0]+=['a']#=>["a"]h[0]#=>["a"]#asexpected这是否与的事实有关?就地更改数组,而Array#+创建一个新实例? 最佳答案 如果您创建一个Hash使用Hash.new的block形式,每次您尝试访问实际上不存在的元素时,都会执行该block。那么,让我们看

ruby-on-rails - 在 Rails 上获取模型或 404

是否可以在Rails上使用get_by_id_or_404函数。例如,在我的Controller中我使用:@destination=Destination.find_by_id(params[:id])如果未设置ID或未找到目的地,我如何让Rails重定向到404页面?谢谢! 最佳答案 在生产模式下,Rails通过呈现404错误页面自动挽救ActiveRecord::RecordNotFound异常。当没有找到结果时,只需使用引发ActiveRecord::RecordNotFound的finder的bang版本。@destinat

arrays - 过滤以从数组中排除元素

尝试从数组中过滤一些条目。不能保证它们在master数组中,所以我正在通过迭代进行测试。total=['alpha','bravo','charlie','delta','echo']hide=['charlie','echo']pick=[]foriintotalif!hide.include?(i)putsipick.push(i)endendputspick这是行不通的。有没有更好的方法来提供这种过滤器? 最佳答案 Ruby允许您在两个数组上使用公共(public)实例方法来获取它们的相交或互斥元素:a1=['alpha','